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(54) Title: CONTENTION SWITCHER 



(57) Abstract 

Electronic switching system (10) for 
making logical connections between at 
least one computer (Cn) and a plurality of 
computer terminal devices (Tn). Each 
terminal (Tn) and each computer (Cn) or 
computer ports is connected to asynchro- 
nous receiver-transmitter for convening 
serial binary data to and from parallel bi- 
nary data. A microprocessor controls the 
making of logical connection between 
each terminal's asynchronous receiver- 
transmitter and the asynchronous receiv- 
er-transmitter connected to a desired or 
selected computer (Cn). A memory con- 
trolled by the microprocessor for storing 
the identity of computer terminal devices 
(Tn) and the respective ART to which 
they are connected, and a connection 
table of current logical connections be- 
tween pairs of ARTs. Sequencer logic cir- 
cuit is controlled by the microprocessor 
for receiving connection request signals 
from one of the terminals (Tn) for con- 
nection to a specific computer (Cn) and 
sequentially establishing a logical connec- 
tion between the ART to which the one 
terminal (Tn) is connected and the ART 
to which the specific computer (Cn) is 
connected. 
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CONTENTION SWITCHER 

BACKGROUND AND BRIEF DESCRIPTION OF THE INVENTION 

Contention switching relates to the ability to switch any 
terminal requesting service into any available port o£ a "HOST" 
computer system. A "many- to-few" relationship, much like a 
rotary telephone system; i.e. fifteen terminals into eight ports. 
This invention relates to a "logical" switcher as opposed to* a 
"physical switcher". The connection la soft instead of being a 
metallic path. 

If service is unavailable* the user requesting service is 
automatically queued for service and will be connected 
automatically when a port becomes available. (Instead of 
"falling off the end";. 

Since operating systems for micro-based systems know 
nothing about switchers, contention switchers incorporating the 
invention to monitor all traffic across every port to determine 
when it may disconnect and give the port to another user. 
Contention switcher incorporating the invention accomodates up to 
sixteen operating systems simultaneously; watching for trigger 
messages, and/or "idle" timeouts, and sending appropriate 
termination sequences. All are user-definable. 

All of the above are extended to as many as sixteen 
"HOSTS" or "GROUPS". While "HOST" generally refers to ports 
associated with a specific host computer.it is synonomous with 
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"GROUP"* which may include groups of modems or terminals. A 
further feature of the invention is that any terminal may be 
designated as a member of a "GROUP*" , and for each group there is 
a master. With a few keystrokes, the master may at any time 
override his group's individual activities, causing their 
keyboards to be locked and his display to be replicated onto 
theirs, without their jobs being terminated. Once released by 
the master, they may resume at the same place. This capability 
is particularly useful in a teaching environment, and for 
demonstrations to groups larger than can gather around a single 
terminal . 

Different computer systems have different standards as to 
data bits, stop bits, and parity, <i.e. ALTOS brand computers 
require 8 data, 1 stop and no parity, while NCR brand computers 
require 7 data, 1 stop and even parity.) Terminals connected 
directly or through a physical switcher would normally require 
reconfiguration to move from one system to another. A further 
feature of the invention is that the connection and data transfer 
is transparent because it is not a metallic path and each port 
stands alone. Different peripheral devices operate at different 
speeds of data transfer. <i.e>, terminals normally operate at 
9600 baud, while modems typically operate at 1200 baud.) This 
invention allows devices of differing speeds to be logically 
switched and connected with total transparency. <i.e. the 
1200-baud modem can be connected to the 9600-baud terminal and 
the invention provides buffering and speed translation, within 
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limits-) Contention switchers incorporating the invention ere 
fully capable of performing data transfer to/from its limit of 
128 ports, and all of the above functions, with zero degradation 
to its users. File transfers are easily and efficiently 
accomplished through the use of the CW tm package or equivalent. 
This invention can accomplish all of the functions of a Local 
Area Network (LAN) with zero degradation at either terminal or 

processor level. 

The basic system consists of thirty-two (32) user ports 
and two system ports (console and logging printer). A dedicated 
console device is not required. 

A feature of the invention is the system is expandable to 
a 128 user ports in increments of 32 ports, all field-installable 
by customer personnel. However, it will be appreciated that the 
principles and features of the invention are not limited to this 
number of ports. 

Contention switchers incorporating the invention are 
command driven, even though the resulting action may be an 
interactive display. Normal use requires as little as a single 
keystroke (i.e. "2") to request the next port on a specific host 
system, but other commands are; 

SETUP TERMINAL CONNECT 

STATUS HOST DISCONNECT 

PORT GROUP TIME 

DIAGNOSTIC 

All system configuration is accomplished through a very 
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user-friendly full-screen interactive display, offering 
soft-setup of each parameter or port attribute. Every port is 
individually configurable to any format, speed, use, group 
designation, privacy restriction and host-connect restriction. 

A full-screen display may be requested at any time to 
show current operating configuration and connections, including 
time-of-day connected, etc. The contention switcher system 
includes battery backup which will, after a power failure, 
provide at least sixty <60> hours of retention of key 
information • 

According to the invention, extensive and exhaustive 
diagnostic programs are held in PROW memory at all times, and 
run both on-line and off-line to veriiy integrity of operation, 
or to point directly to the source of the problem. 

Even though there may be as many as twelve events 
occurring simultaneously, all are executed through 
Large-Scale-Integration (LSI or VLSI ) circuitry and there are no 
moving parts except for fans. 

Power failure is automatically sensed Cor may be 
requested by pressing the logic power switch) and shutdown 
handled by the invention. When power is again available, the 
system is automatically brought back up. The Systems 
Administrator may assign to each terminal port the ability to 
configure and further to execute diagnostics from that port. 
Also, the port and its attached terminal may be allowed or denied 
access to specific hosts or groups. ^ v oqq£ 



WO 87/00317 



- 5 - 



PCT/US86/01219 



In the disclosed embodiment, every fourth port has full 
modem capabilities and may be used to interface to the outside 
world through modems. 

BRIEF DESCRIPTION OF THE DRAWINGS: 

The above and other objects, advantages and features of 
the invention will become more apparent when considered with the 
following specification and accompanying drawings representing 
an exemplary embodiment of a contention switching system 
Incorporating the invention wherein: 

Fig. 1 is a schematic block diagram of a contention 
switching system in accordance with the present invention. 

Fig. 2 is a schematic block diagram of the central 
processing unit (CPU) incorporating the invention, (and shown in 
greater detail in Figs. 8-32), 

Fig. 3 is a schematic block diagram of the polling assist 
hardware components incorporated in the invention, 

Fig. 4 is a schematic block diagram of one of the 
input/output (0/1) boards incorporated in the invention (and 
shown in greater detail in Fig.s 33-39), 

Figs. 5a, b and c are flow charts illustrating the system 
initialization sequence according to the invention. 

Figs. 6a and b are flow charts illustrating the system 
connect and disconnect sequence according to the invention. 

Figs. 7a, b, c, d, e, f, g and h are flow charts 
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illustrating the various interrupts of the system, and 

Figs, 6-39 are detailed circuit diagrams of. a contention 
switcher incorporating the invention. 

GLOSSARY - CONTENTION SWITCHER 



The following list defines various terms related to the 
contention switcher which are used throughout this specification. 
BAUD RATE-The unit of signaling speed indicating the number 

of signal transitions per second that occur over 

a data communications channel. 
COMMAND CONSOLE- A data terminal through which the contention 

switcher is controlled. 
CONFIGURATION- The complete specification of all of the 

necessary parameters required to operate the 

contention switcher in a &p&<zl£ 1c operating 

environment. 

CONNECTION SEQUENCE- The dialogue entered at a terminal port which 
causes a logical connection to be made to a host 
port. 

CONNECTION TABLE- An internal list of the current logical 
connections. 

CONTENTION SWITCHER <CTSW)- A single piece of equipment designed 
to replace the function of many pieces of data 
communication equipment by creating logical 
connection paths internally between any two of 
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its external porta. The contention switcher may 
be connected to other data communication 
equipment only if the interconnecting cable has 
certain signal lines crossed. 

CONTROL REGISTER- A special latch used by the microprocessor to 
control control specific hardware on the CPU 
board, such as the status indicators and/or the 
Watchdog Timer. 

CPU BOARD- Printed circuit card containing the 

microprocessor, system memory, time of day clock, 
programmable timer, sequencer logic, and 
console/error logger interface. 

DATA COMMUNICATION CHANNEL- The entire communications interface, 
including but not limited to a piece of data 
terminal equipment connected to data communication 
equipment which is in turn connected to another 
piece of data communication equipment and finally 
terminating at another piece of data terminal 
equipment. 

DATA COMMUNICATION EQUIPMENT (DCE) - A device for the conversion 
of a serial binary data stream to and from 
signals suitable for transmission over long 
distances, specifically telephone lines. Also 
referred to as a MODEM. The EIA Standard RS-232-C 
specifies that a female connector is to be 
associated with DCE . 
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DATA TERMINAL EQUIPMENT (DTE) - Any device used f«;r the display 
and transmission of serial data. A computer 
(being capable of displaying and transmitting 
serial data) may also be referred to as Data 
Terminal Equipment. The EIA Standard RS-232-C 
specifies that a male connector is to be 
associated with DTE , although this convention is 
frequently not adhered to. 

DIAGNOSTICS- Special commands which are entered at the command 
console which exercise various portions of the 
CTSW in order to detect and identify hardware 
failures. 

DISCONNECT TIMEOUT- A period of time after which, if no data 
activity is detected, a logical connection is 
broken. 

DUAL ASYNCHROUNOUS RECEIVER -TRANSMITTER < DUART ) - A signal 
integrated circuit chip containing all of the 
digital logic necessary to perform the conversion 
of serial binary data to and from parallel binary 
data for two ports. The DUART used in the 
embodiment is the MC68681. 
EIA- Electronic Industries Association 

2001 Eye Street, N.W., Washington, D.C. 20006 
FIFO- A self -addressed memory chip that remembers the 

order that data is stored into it, such that the 
first data written into it is automatically the 
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first data -to be read out of it. (First In. Firat 
Out> • 

GROUP- A collection of one or more ports which are 

handled as a unit* Groups are defined by the 
GROUP command. 

HOST PORT- Any one of the data communication channels which 

is connected to an external computer port. The 
connection may be directly to the computer or 
through a MODEM. 

I/O BOARD- Printed circuit card containing sixteen DUARTa 

and the necessary interface logic required to 
access those DUARTs from the CPU board. This 
board also contains 'the signal drivers and 
receivers that go to the interface connectors on 
the back of the contention switcher. 

INTERRUPT- An electrical signal generated in order to notify 

the microprocessor of an external condition that 
requires the attention of the central processing 
unit. 

INTERRUPT PRIORITY LEVEL (IPL>- The relative importance assigned 
to each interrupt which indicates to the 
microprocessor which interrupt to handle first if 
more than one external device requires it's 
attention at the same time. 

LOGICAL CONNECTION- A connection between two ports of the CTSW. 
Once a logical connection is made, the two ports 
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behave as if they are physically connected to 

t 

each other, although there is a slight delay 
introduced by the CTSW of less than one character 
transmission time plus one millisecond. 

MASTER TERMINAL- A data terminal that is connected to a port 
which is configured to control one or more slave 
terminal ports. 

MEGAHERTZ- One million cycles per second. 

MODEM (MOdulator/DEModulator)- See DATA COMMUNICATION EQUIPMENT. 

MICROPROCESSOR- The central processing unit used to maintain 
control over all of the internal functions of the 
contention switcher. The microprocessor used is 
the MC68OIO. 

NORMAL /SERVICE SWITCH- A two position switch located on the CPU 
board which is used to lockout certain commands 
which if inadvertently entered could destroy the 
configuration. 

OPERATIONAL MODE- The normal mode of operation for the CTSW. 

Certain diagnostic commands which could interfer 
with normal operating of the CTSW are not allowed 
to be entered. The opposite of operation mode is 
shutdown mode . 

POLLING- The regular examination by the sequencer of the 
DUART ports used to transfer data between the 
ports. 

PORT- An electrical passageway into or out of a 
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computer or a computer related piece of equipment 
used for data communication. Also used to refer 
to one of the two data communication channels in 
a DUART. 

PROGRAMMABLE TIMER- An intergrated circuit chip used to generate 
precisely timed interrupts. The timer used is 
the MC6840. 

REAL TIME CLOCK- An integrated circuit chip used to keep track of 

the time of day and the current date. Also 

referred to as "Time of Day Clock". 
RS-232-C- An EIA standard defining an "Interface Between 

Data Terminal Equipment and Data Communication 

Equipment employing Serial Binary Data 

Interchange" • 

SLAVE TERMINAL- A terminal configured to be under the control of 
a master terminal. When the master terminal 
enters the override command, the characters 
entered at the slave terminal port art ignored, 
and a copy of the data received from the host 
port connected to the master terminal port is 
transmitted to the slave terminal • 

SHUTDOWN MODE- The mode of operation that the CTSW is required 
to be in order to run diagnostics. No new 
connections are allowed to be made at any of the 
terminal ports . 

TERMINAL- See DATA TERMINAL EQUIPMENT. 

CY 4003 



WO 87/00317 



PCT/US86/01219 



- 12 - 

TERMINAL PORT- Any one of the contention switcher ports which is 
connected to data terminal equipment. The 
connection may be directly to a terminal or 
through a MODEM - 

TIME OF DAY CLOCK- See REAL TIME CLOCK • 

TRIGGER MESSAGE- A one to sixteen character string, which when 
received by the CTSW from a host port, initiates 
a disconnect timeout sequence, 

WATCHDOG TIMER- A special programmable timer which, if not 
regularly attended to by the microprocessor, 
assumes that the CPU has failed and causes a 
system reset to occur. 

DETAILED DESCRIPTION OF THE INVENTION 

Referring to Fig. 1, a microprocessor controlled 
contention switcher 10 incorporating the invention, has a 
plurality of ports 11 (typically ElA-Standard RS-232-C) for 
handling logical connections between one or more computers 12, 
13, 14... Cn (sometimes designated host) and multiple peripheral 
devices such as. terminals 15, 16, 17, 18... Tn. According to the 
invention, if a user of any of the terminal devices wishes to be 
connected to a particular computer, a request is entered on his 
terminal. The contention switcher 10 determines if any of the 
ports of the user selected host computer are available and, if 
available, achieves a logical connection (as opposed to a 
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physical switched metallic path or connection) between the 
requesting terminal and the selected computer. If all of the 
ports of the selected computer are being used (it being 
appreciated that the host computer can, in some cases, only have 
one port) the requesting user will be advised of how many are 
waiting, if they wish to wait and be queued for service by the 
selected computer, if that user so desires- Once the logical 
connection path of a terminal has been made to a selected host 
computer, the contention switcher monitors all data traffic 
across every port. 

INTRODUCTION TO SYSTEM DESCRIPTION 

This specification describes the hardware and software 
used to implement one embodiment of a contention switcher (CTSW) 
incorporating the invention. The CTSW is capable of handling up 
to 64 logical connections between a maximum of 128 EI A Standard 
RS-232-C devices, at data rates up to 9600 baud. 

In the embodiment disclosed herein, the CTSW includes one 
CPU board and from one to four I/O boards. The CPU 20 used is 
the MC68010 16-bit microprocessor which is run at 8 megahertz. 
Each I/O board contains sixteen MC6S681 Dual Asynchrounous 
Receiver/Transmitter CDUART) chips 30. Each DUART 30 is capable 
of handling two RS-232 ports 31A and 31B, for u total of 32 ports 
per I/O board. Each port is connected to a terminal (Terminal 
Port) or to a selected host computer port (Host Port). Both the 
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CPU board and the I/O boards contain special hardware used to 

< 

assist the microprocessor 20 in handling the intense data rates 
required. 

The CPU board contains the system memory 35, including up 
to 8K bytes of battery backed up RAM 35B-1 and 35B-2, used to 
maintain the system configuration when power is removed from the 
CTSW. A Time of Day Clock is also maintained by the battery 
backup system. A programmable timer is used to generate the 
regular interrupts needed to keep data moving in a timely manner. 
One DUART on the CPU board handles two RS-232 ports which are 
not part of the 128 switched ports. These two ports are used to 
communicate directly with the processor in order to update the 
system configuration, log connection information, and run 
diagnostics in the case of a system failure. 

A sequencer logic circuit 50 is controlled by a 
microprocessor 20 for receiving connection request signals from 
one of the ten . There are two basic modes that the processor 
operates in to handle DUART I/O. Initially, all ports are 
handled on a 100* interrupt driven basis. As logical connections 
are made between ports, they are mapped into a connection table. 
Periodically, all DUART ports entered into this table are polled 
in order to do any necessary character data transfers between 
them. This defines an asymmetrical operation, both interrupt 
driven and polled, so that initially the CPU can deal with a 
greater number of interrupts. As more connections are made, less 
time is available for handling the interrupts, but less time is 
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needed. The worst case polling loop would consume approximately 

50* of the CPU time, leaving approximately 50* for handling 
interrupts. The best case would be 0* polling time and 10 Ox 
interrupt handling. The polling loop overhead is totally 
dependent upon the number of logical connections at any given 
time. 

SYSTEM INTERRUPTS DESCRIPTION 



The system processor can be interrupted from any of a 
number of external events. The following descriptions are 
ordered from the highest priority event to the lowest. All 
interrupts (except System Reset) are initially disabled from 
interrupting the processor until the Interrupt Enable bit is ©et 
in the CPU Control Register. 

SYSTEM RESET- is generated upon initial power-up of the system 
or by the RESET push button on the CPU board. A 
reset is also forced i± the watchdog timer enable 
bit is set in the CPU Control Register and the 
programmable watchdog timer is allowed to count 
down to zero. 

SYSTEM ABORT- 

IPL « 7 is generated by the Abort push button on the CPU 

board. This interrupt is also caused by a power 
fail indication from the power supply of a FIFO 
Full condition from the CPU board interrupt 
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handling circuitry. 
PTW INTERRUPT- 

IPL =6 ia generated by the Programmable Timer and la 

used to initiate polling of the I/O board DUARTs 
on a regular baaia • 

RTC INTERRUPT- 

IPL =5 ia generated by the Time of Day Clock once each 
second. It is used to maintain the system clock 
and to timeout idle system ports. 

CPU Board DUART- 

IPL = 4 This Interrupt is generated by the DUART on the 

CPU board. 
I/O FIFO Full- 

IPL =3 ia generated i± on of the FIFOs on any of I/O 

boards reaches it's maximum capacity of sixteen 
interrupting DUARTs . This interrupt is used as a 
load balancing mechanism, giving I/O board(s) 
that have an excess number of pending interrupts 
priority over I/O boards that are less busy. 

I/O Board DUART- 

IPL = 2 This interrupt is generated when any of the I/O 
Board DUARTs requires attention. These 
interrupts are presented to the microprocessor in 
a round-robin fashion by the hardware. 

SHUTDOWN SWITCH- 

IPL * 1 This interrupt indicates that the front panel 
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Startup/Shutdown switch is requesting that the 

r 

system should be shutdown* 
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FORMAT OF OFF BOARD DUART REGISTER ACCESS WORD 



-ADDRESS LOOP BACK ENABLE BIT 



I 4 DUART INTERRUPT ACKNOWLEDGE 

1 I 

A17 A16 AIS A14 A13 A12 All AlO A9 A8 A7 A6 AS A4 A3 A2 Al AO 



! ALB t ACK i SS4 1 SS3 ! SS2 i SS 1 J RS3 ! RS2 ! RS 1 ! BS3 I BS2 ! BS 1 ! CS4 1 CS3 ! CS2 ! CS 1 i RS4 i XX X ! 

<ssw»amas*sssss«> < aanc=ir=aa > <o»»n=5B«») < o s s aaaBwaaaB > < at > <■> 



I t i : 

POLLING SEQUENCE SELECT i 

: 

REGISTER SELECT 3,2,1 ■ - » I 



J 



BOARD SELECT 3,2,1 ■ 
CHIP SELECT 4,3,2,1 
REGISTER SELECT 4 — 



1 
I 
I 
6 
N 
0 
R 
E 



NOTES : 

1> BIT O DEFINES EVEN OR ODD BYTE ADDRESSES. DUARTS WAY 
BE ACCESSED AT EITHER EVEN WORD OR ODD BYTE ADDRESSES. 

2) THE POLLING SEQUENCE SELECT IS DECODED AS FOLLOWS: 

0000 - ABSOLUTE DUART ACCESS 

0001 - POLLING SEQUENCE STEP 1 

POLLING SEQUENCE 

0111 - POLLING SEQUENCE STEP 7 

11000 - DUART INTERRUPT ACKNOWLEDGE (READ ONLY) 

01000 - FIFO FULL INTERRUPT RESET 

1001 - DIAGNOSTIC SEQUENCE STEP 1 

DIAGNOSTIC SEQUENCE 

1111 - DIAGNOSTIC SEQUENCE STEP 7 

ADDRESS LOOPBACK ENABLE IS ONLY VALID FOR DIAGNOSTIC 
STEPS REFER TO POLLING SEQUENCE STEP DEFINITION FOR WORE DETAIL, 



CY 4010 



WO 87/00317 



PCT/US86/01219 



- 19 - 

3> THE FOLLOWING TABLE DEFINES THE UTILIZATION OF THE 
DUART INPUT AND OUTPUT PORT PINS: 

OPO = CTS A IPO = RTS A 

0P2 « DSR A IP2 * DTR A 

OP3 - DSR B IP3 * DTR B 

IP4 « DCD A »• 
•« - MODEM PORTS ONLY IP5 = RI A »• 



ADDRESS J 

*E041FE ! 

*E04t00 i 

*E040FE 1 

SE04000 : 

*E020FE ! 

*E02000 I 

♦EOOOFE I 

SEQO0OO * 



SPECIAL PURPOSE CPU BOARD RAM MAP 
UPPER DATA BYTE LOWER DATA BYTE 



EXPANDED COMPARE RAM i *E041FF 
OPTION <128 BY 8 BITS) I *E0410i 



HARDWARE COMPARE RAM 1 *E040FF 

(128 BY 8 BITS) i SE04001 

HARDWARE POINTER RAM I #E02OFF 

(128 BY 8 BITS) I *E0200i 

HARDWARE MAPPING RAM I SEOOOFF 

(128 BY 8 BITS) ! *E0OOOl 



NOTES : 

1> The Hardware Compare RAM contains up to 8 short 
messages. Each message can be up to 16 characters in length. 
Only the low 7 bits are used for the compare operation. The MSB 
(bit 7) of the character from the Compare RAM indicates the last 
character of the message. If set, and the final character 
matches the received character, then Bit 7 of the status byte 
written into the Pointer RAM is set indicating a complete match. 
Bit 2 of the Status byte will be cleared, in order to determine 
if any characters are received after the match occurs. 
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23 The Hardware Pointer RAM is addressed by bits A7 - Al 
of the DUART Register address/command word. During a polling 
sequence, the Hardware Pointing RAM is used to address the 
hardware Compare RAM . If the character read from the Compare RAM 
matches the character read from the DUART then the low 4 bits of 
the pointer are incremented to point to the next character. 
Otherwise the low 4 bits of the pointer are reset to point to the 
beginning of the short message. 

CY4012 

ON BOARD I/O DEVICE ADDRESS MAP 



ADDRESS * UPPER DATA BYTE LOWER DATA BYTE I 



1 

t 


MC6840 ! PROGRAMMABLE TIMER 


i $DC0FFF 


$DC000E i 


! WR TIMER 3/RD LSB BUF 


I $DC0O0F 


socoooc : 


i WR MSB BUF/RD TIMER 3 


i $DC000D 


SDCOOOA t 


I WR TIMER 2/RD LSB BUF 


I $0C0OOB 


$DC0008 ! 


i WR MSB BUF/RD TIMER 2 


I $DC0009 


$DC0006 i 


i WR TIMER l/RD LSB' BUF 


i $DC0007 


socooo4 : 


! WR MSB BUF/RD 'TIMER 1 


; $ocooo5 


$DC0002 ! 


1 WR CREG 2 /READ STATUS 


1 $OC0003 


SDC0000 ! 


i WRITE CONTROL REG 1/3 


f $000001 






i 


MCI 468. 18 i DATE / TIME CLOCK 


i $D80FFF 


$D8007E ! 


! HIGHEST RAM BYTE 


t $080O7F 


$D8001C i 


» LOWEST RAM BYTE 


1 $080010 


soeooiA : 


I MISC REGISTER 0 


1 $D8001B 


$080018 ! 


! J1ISC REGISTER C 


I $080019 


$080016 i 


! MISC REGISTER B 


1 $D80017 


$D80014 : 


! MISC REGISTER A 


! $DS0013 


$oaboi2 : 


! YEAR REGISTER 


! $D80O13 


$080010 t 


! MONTH REGISTER 


I $080011 


$dsoooe « 


I DAY OF MONTH REG 


i $D8000F 


$D8000C : 


! DAY OF WEEK REG 


t $080000 


$D8000A 1 


i HOURS ALARM REG 


1 $D80008 


toeoooe i 


i HOURS REGISTER 


I $080009 


$oeooo6 : 


! MINUTES ALARM REG 


( $080007 


$080004 1 


! MINUTES REGISTER 


1 $080003 


$080002 J 


! SECONDS ALARM REG • 


t $080003 


$080000 i 


i SECONDS REGISTER 


i $D80001 
— * 




MC 68681 ! CPU BOARD DUART (S) 


1 $D00FFF 


$000E02 I 


i STOP CTR/QP BIT RESET 


1 SD00E03 


$D00C02 1 


i STRT CTR/OP BIT SET 


1 $DOOC03 


$OO0AO2 J 


i INPUT PORT / OPCR REG 


1 $00OAO3 


$000802 : 


{ INTERRUPT VECTOR" REG 


i $000803 


$000602 ' 


! RCVR/XMITTER BUFFER B 


i $000603 


$000402 t 


t COMMAND REGISTER B 


( $000403 


$000202 I 


! STATUS / CLK-SEL REG B 


t SD00203 


$D00002 ! 


! MODE 1/2 REGISTER B 


'. $000003 


$oooeoo i 


i CTR / TIMER LOWER REG 


1 $000EOl 


$DO0CO0 1 


! CTR / TIMER UPPER REG 


! $DOOC01 


$0O0AO0 1 


! INT STATUS / MASK REG 


1 $000 AO 1 


$000800 i 


! IP CHANGE/ AUX CTL REG 


t $000801 


$000600 ! 


i ' RCVR/XMITTER BUFFER A 


i $D00601 


$000400 : 


i COMMAND REG I STER A 


! $000401 


$000200 1 


i STATUS / CLK-SEL REG A 


1 $000201 


$000000 i 


i MODE 1/2 REGISTER A 


: $000001 
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CPU BOARD I/O REGISTER ADDRESS MAP 



AODRESS t 



UPPER DATA BYTE 



LOWER DATA BYTE 



tCCOOOO I 
*C800O0 I 
♦C40000 I 



! INT 01 AG REGISTER (W/0) I *CCOOOi 
i STATUS REGISTER <R/0) t SC800O1 
I CONTROL REGISTER tR/W) I SC40OO1 



13-8 



CONTROL 
REGISTER 



3 4 3 2 

„.+ 4— — 



0 

4.— + 



I NOT USED « LE4 J LE3 ! LE2 ! LEX I WRE ! WPE ! WDT i INT i (READ/WRITE) 



LEI THRU LE4 - CPU BOARD LED I THRU LED 4, 0« EXTINGUISH, 1 - ILLUMINATE 
WRE - WRITABLE RAM ENABLE/DISABLE CONTROL, 0 * DISABLE, 1 - ENABLE 
WPE - WRITE PROTECT ENABLE/DISABLE CONTROL, 0 « DISABLE, 1 * ENABLE ' 
WDT - WATCH DOG TIMER ENABLE/DISABLE CONTROL, 0 - DISABLE, I ■ ENABLE 
INT - MASTER INTERRUPT ENABLE/DISABLE CONTROL, 0 « DISABLE, 1 - ENABLE 
13 -9 76 3 43210 



STATUS 
REGISTER 



; NOT USED iN/S:ACF:CJilCJOiWRE:WPT:WDT!INT: (READ ONLY) 



WRE, WPT, WDT, INT - IDENTICAL TO CONTROL REGISTER BITS 

N/S - NORMAL/SERVICE MODE SWITCH, fi - NORMAL , 1 - SERVICE 

ACF - A/C POWER FAILURE DETECTION, 0 « NOT FAILED, 1 « FAILED 

CJ1 AND CJO CONFIGURATION JUMPERS, 0 * INSTALLED, 1 = REMOVED 

THE CJ2-CJ1 JUMPERS WILL BE INTERPRETED AS FOLLOWS: 

BOTH JUMPERS INSTALLED *= 9600 BAUD CONSOLE PORT 
CJl ONLY INSTALLED « 1200 BAUD CONSOLE PORT 
CJO JUMPER INSTALLED = 300 BAUD CONSOLE PORT 
BOTH JUMPERS REMOVED » 110 BAUD CONSOLE PORT 



13 



8 



INTERRUPT 

DIAGNOSTIC 

REGISTER 



! not used !FF3:ff2:ffi:ffo:ip3!IP2:ipi:ipo: (write only) 



FF3 THRU FFO - SIMULATE FIFO FULL , 0 » INTERRUPT, I - NO INTERRUPT 

IP3 THRU IPO* - SIMULATE INTERRUPT PENDING, 0 « INTERRUPT, 1 ■ NO INTOtfUPr 

PROGRAMMABLE ARRAY LOGIC (PAL) BOOLEAN SPECIFICATION 

CY 4013 



The following specification is used to program the PAL 
that decodes the memory address into several general categories 
of access (IOEN, HDRAM, LOCIO, MCSRG, LOCM) • This PAL also 
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indicates an interrupt acknowledge cycle CINTAC) or non-interrupt 
(FCHI) cycle. It generates the signal ERREN » if a user mode 
access is attempted with the PROTect bit set in the CPU Control 
Register. 



PAL1&L8 PAL DESIGN SPECIFICATION 

PATTERN 02-4038PU1 4/1/84 SUMCHECK - 4248 

CATEGORY DECODER FUSES BLOWN « 

A23 A22 A21 A20 FCO 

FC1 FC2 DAS1 PRQT GND 

/OE /I0EN /FCHI /LDCIO /LOCM 

/CRGS /HDRAM /INTACK /ERREN VCC 

IF (OE) I0EN « A23 ♦ A22 « A21 ♦ A20 * FC2 * FCHI 

IF <0E) FCHI » /FC2 + /FCl + /FCO 

IF (OE) LOCIO » A23 * A22 * /A21 ♦ A20 * FCHI 

, IF (OE) LOCM « /A23 ♦ /A22 * /A21 # FCHI 

IF (OE) CRGS « A23 * A22 * /A2i ♦ /A20 * FCHI 

IF (OE) HDRAM » A23 • A22 ♦ A21 ♦ /A20 ♦ FCHI 

IF <OE> * INTACK = FC2 ♦ FCl * FCO ♦ DAS1 

IF (OE) ERREN '» /FC2 ♦ PRQT 



PROGRAMMABLE ARRAY LOGIC CPAL) BOOLEAN SPECIFICATION 



The following specification is used to program the PAL 
that decodes the general category of access into several specific 
enable/clocking signals ( OUSEL , RTCSEL , PTMSEL, MCRWR, MSRRD, 
IDRWR) . It also generates Valid Peripheral Address <VPA) back to 
the microprocessor, and an error signal < ERREN ) if an invalid 
access is attempted. 
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PAL16L6 

PATTERN 04-4C3BPU4 
SELECT DECODER 



PAL DESIGN SPECIFICATION 



7/13/84 SUMCHECK ■ 8308 
FUSES BLOWN » 1017 



A19 
WRITE 
DAS1 
MCRWR 

IF(VCC) 



IF(VCC) 
IF(VCC) 
IF(VCC) 
IF(VCC) 
.IF(VCC) 

IF(VCC) 
IF(VCC) 



A18 
FC2 
/ IOERR 
/MSRRD 



/ERREN 
/LOCIO 
/DUSEL 
IDRWR 



/VMA 
/CRGS 
/RTCSEL 
/VPA 



/ I NTACK 
GND 

/PTMSEL 
VCC 



IOERR « DASt • ERREN ♦ LOCIO 

♦ DAS1 * LOCIO ♦ /A19 # A18 

♦ VMA ♦ /FC2 * CRGS 

♦ VMA ♦ CRGS ♦ /A19 * /A18 
+ VMA ♦ WRITE ♦ CRGS # A19 • /A18 

♦ VMA ♦ /WRITE * CRGS • A19 * A18 

DUSEL - 0AS1 • /ERREN ♦ LOCIO * /A 19 ♦ /A 18 

RTCSEL » DAS1 ♦ /ERREN * LOCIO * A19 * /A IB 

PTMSEL » DAS1 • /ERREN * LOCIO » A19 ♦ A18 

/MCRWR - /FC2 ♦ /VMA + /CRGS + A19 ♦ /A18 + /WRITE 

MSRRD » FC2 ♦ VMA ♦ CRGS * /A19 * A18 # /WRITE 
+ FC2 * VMA * CRGS * A19 * /A18 • /WRITE 

/IDRWR » /FC2 * /VMA ♦ /CRGS ♦ /A19 ♦ /A18 ♦ /WRITE 

VPA « DAS1 ♦ CRGS 

♦ DAS1 • INTACK 

♦ DAS1 * LOCIO * A19 * /A10 



OVERVIEW OF OFFBOARD DUART I/O HANDLING 



When a successful connection sequence is entered at a 
terminal port, the selected host port and the terminal port are 
logically connected by entering their I/O addresses into a RAM 
(Mapping RAM) on the CPU board. One bit of these I/O addresses 
is used to define an optical master /slave relationship between a 
configurable group of terminals. The master terminal may enter a 
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command which will cause all sieve terminals to be driven with 
the characters received from the master terminal's host port. 
Additionally, while these terminals are slaved, no data will be 
transferred to their respective host ports. 

Once a pair of DUART ports have been logically connected, 
a regularly timed polling sequence conditionally transfers data 
between them- First, the status of the two ports is latched on 
the CPU board. If the status latched indicates that the receiver 
is ready in the source DUART and that the transmitter is ready in 
the destination DUART then (except for a slaved terminal port) a 
MOVE instruction will transfer the data from the source DUART 
receiver to the destination DUART transmitter. If any required 

condition is not met, then the I/O Enable signal to the VERSABUS 
will not be asserted (as well as other signals associated with 
the message compare logic described below) and the MOVE 
instruction will have no effect on the DUARTs addressed. The 
MOVE instruction is executed, irregardless of the latched status. 
Therefore, the MOVE is a hardware conditional, rather than a CPU 
internal test. 

As each character is received from a selected host port, 
it is compared to one of 8 short messages contained in a RAM 
(Compare RAM) on the CPU board. As each character of the message 
is matched, a pointer in another RAM (Pointer RAM) is 
incremented. If the MSB of the character read from the Compare 
RAM is set, and that character matches the character being 
received, a bit is set in a status byte which is written into the 
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pointer RAM, indicating that the message has been completely 
matched. This etatus byte is periodically checked by the 
processor, and if no characters are received from the terminal 
port within a configurable timeout period, the connection will be 
terminated • 

Abnormal DUART conditions (Overrun Error, Framing Error, 
Received Break, Input Change) are always processed by the DUART 
interrupt handler. I/O board DUART interrupts are queued in a 
"FIFO" on the I/O board, so that they can be processed on a first 
come, first serve basis. In order to handle multiple DUART 
interrupts in an efficient manner, the DUART interrupt handler 
uses a special address/command word to acknowledge DUART 
interrupts. After entering the DUART interrupt handler, this 
address/command word is read to determine the address of 
interrupting DUART • After handling the interrupt, this address 
is read again to determine the address of the next DUART to 
handle. If the address byte read is ZERO, then no more DUART 
interrupt are pending and the interrupt handler is exited. 



POLLING LOOP TIMING 



An interrupt from the MC6840 programmable timer initiates 
a polling loop once every 900 microseconds. The polling loop 
initializes seven- address registers with the address/commands 
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used to poll each pair of logically connected DUART porta. Then 
the following sequence of five instructions is executed for each 
logical connection : 

LATCH TERMINAL PORT DUART ADDRESS 
LATCH TERMINAL STATUS-HOST DUART ADDRESS 
LATCH HOST STATUS-COMPARE RAM ADDRESS 
MOVE DATA <HOST TO TERM) -CHECK MESSAGE 
MOVE DATA (TERM TO HOST) -STORE STATUS 
Word access is used so that at the end of each polling 
sequence each address/command has been incremented by two. The 
'next polling sequence will then address the next connection pair. 

The following table shows the expected execution time 
necessary to process one complete polling loop for the 8 
Megahertz CPU : 



TST.W 
TST.W 
TST.W 
MOVE.W 
MOVE . W 



(AO)- 
(AD- 
(A2)- 

<A3) (A4> + 
(AS) < A6) ♦ 



FUNCTION 


UNIT 




OF CYCLES l 


CYCLES 


uSECS 


Interrupting the Processor 


44 






44 


5.5 


Saving Register Contents 


20 + 


8 


X 8 Registers 


84 


10.5 


Setup -for Polling Loop 


20 + 


8 


X 9 Registers 


84 


10.5 


Entering the Polling Loop 


14 + 






20 


2.5 


Poll each Logical Connection 


48 X 


64 


POLLS MAX 


3072 


384.0 


LOOP instruction Overhead 


4 + 


10 


per 8 POLLS 


84 


10.5 


Restoring Register Contents 


20 + 


S 


X 8 Registers 


84 


10.5 


Exiting from the. Interrupt 


24 






24 


3.0 














TOTAL MAXIMUM EXECUTION TIME 








3496 


469.0 
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POLLING LOOP SEQUENCE DEFINITION 



The following taJDle shows the utilization o£ the latches 
used to implement the hardware assisted polling sequence. An "X" 
is placed at each step in the sequence where data is either 
clocked into a specific latch or a specific latch's output is 
enabled for a particular use. Reference the BLOCK DIAGRAM OF 
POLLING ASSIST HARDWARE shown in Fig. 3 for the location of each 
latch. 



TERMS LAT LAT LAT LAT LAT LAT LAT UAT LAT LAT LAT LAT LAT 

1 122345667786 SEQ 

STEPS CLK ENA CLK ENA CLK CLK CLK CLK ENA CLK ENA CLK ENA « 



TST <AO>«- » X I 
TST <A1>* '1 

TST <A2)* I 

MOVE <A3)+, I 

(A4)* ; 

MOVE (A3)*, I 

(A6)+ J 



i X I X 



1 X I 

: x ; 



i 



i x 
i 



! 



IX t 



t X 



1 1 t 

I 2 t 

I 3 t 

t 4 I 
XSSI 

I 6 1 

i 7 r- 



LATCH 


1 - 


Holds the address of the Terminal Port and* Slaved Bit 


LATCH 


2 - 


Holds the address of the Host Port and Master Bit 


LATCH 


3 - 


Holds the status register from the Terminal Port DUART 


LATCH 


4 - 


Holds the status register from the Host Port DUART 


LATCH 


5 - 


Holds the pointer used to address the Compare RAH 


LATCH 


6 - 


Used to update the Compare RAM address pointer 


LATCH 


7 - 


Used to update the Hardware Sequencer Status Byte 


LATCH 


8 - 


Holds a character to be output to Slaved Terminal Ports 
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NOTE : The outputs of latches 3, 4 and 5 are enabled during the 
entire poling sequence. 
The following table shows the utilization of the RAMs 
used to Implement the hardware assisted polling sequence. An "X" 
is placed at each step in the sequence where data is either read 
into a specific RAH or a specific RAM's output is enabled for a 
particular use. Reference the BLOCK DIAGRAM OF POLLING ASSIST 
HARDWARE for the location of each RAM. 



TERMS 


POINTER 


COMPARE 


MAPPING 


MEMORY 


SEQUENCE BITS 




RAM 


RAM 


RAM 


ACCESS 








STEPS 


ENABLE 


ENABLE 


ENABLE 


CYCLE 


14 


13 


12 11 


TST <A0> + 


1 : 




x : 


READ 


0 


0 


0 1 


TST <A1) + 


: t 




: x : 


READ 


! .0 


0 


1 0 


TST (A2)+ 


i x : 




i 

• i 


READ 


0 


0 


1 1 . 


MOVE <A3)+, 


i X ! 


X 


I i 
i 


READ 


, 0 


1 


0 0. 


(A4) + 


t . X ! 




i 

i 


WRITE 


0 


1 


0 1 


MOVE <A5>+, 


: x : 




i 
t 


READ 


0 


1 


1 0 


<A6) + 


J X I 




* i 


WRITE ! 


0 


1 


1 1 . 



PROGRAMMABLE ARRAY LOGIC (PAL) BOOLEAN SPECIFICATION 



The following specification is used to program the PAL 
that enables the RAMs and the bu±±ers used to directly access 
those RAMs that are apart of the polling assist hardware. 

This PAL also generates the DUART acknowledge (DUACK) and 
the FIFO Interrupt Reset (FFRST) signals. 
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■sasv«ssss8ssa3sasasasosasB3S3sa 



PAL16L8 

PATTERN 06-60 IFPU6 
SEQUENCE DECODER 1 



PAL DESIGN SPECIFICATION 



7/13/84 SUttCHECK - 3216 
BLOWN FUSES » 632 



A13 
/WRITE 
DAS2 
/83ENA 



A14 

/HDRAM 

/MAPENA 

/SIENA 



A13 
OAS 

/PTRENA 
/FFRST 



A1Z 
A16 

/CMPENA 
/DUACK 



/IOEN 
GND 
/B4ENA 
VCC 



IF(VCC) B4ENA * DAS2 ♦ HDRAM * /AIS ♦ /A14 ♦ /A13 

IF<VCC> MAPENA ■ DAS ♦ HDRAM * /AIS * /A14 • /A13 

♦ 0AS2 • IOEN ♦ /A14 * /A13 * A12 

♦ DAS2 ♦ IOEN # /A14 # A13 * /A12 

IF(VCC) B1ENA - DAS2 # HDRAM + /A13 ♦ /A14 # A13 

IF (VCC) PTRENA - DAS ♦ HDRAM * /A15 * /A14 ♦ A13 

♦ DAS2 * IOEN # /A14 # A13 ♦ A12 
+ /WRITE * DAS2 ♦ IOEN ♦ A14 

♦ WRITE • DAS ♦ IOEN # A14 

IF(VCC> B3ENA • DAS2 ♦ HDRAM ♦ /A13 * A14 # /A13 

IF(VCC) CMPENA • DAS ♦ HDRAM * /A15 * A14 * /A13 

♦ DAS2 • IOEN ♦ A14 # /A13 * /A12 



J ADDR *EOOXXX 

} ADDR *EOOXXX 

|Sl f Dl 

;S2 f D2 

1 ADDR *E02XXX 

I ADDR *E02XXX 
| S3 , 03 . 
IS4-S7,D4-D7 
1S4-S7, 04-07 

I ADDR *E04XXX 

1 ADDR *E04XXX 
; S4-D4 



IF (VCC) FFRST « DAS * IOEN * /A16 * A15 ♦ /A14 • /A13 ♦ /A12 ; SEQ 8 
IF(VCC) DUACK - /WRITE ♦ IOEN * A16 * A13 ♦ /A14 ♦ /A13 * /A12 . J SEQ 8 



PROGRAMMABLE ARRAY LOGIC <PAL> BOOLEAN SPECIFICATION 



The following specification is used to program the PAL 
that enables the latches that supply various data during the 
hardware assisted polling sequence. 

This PAL also generates the enables for the buffers used 
to drive address (B5ENA) and data <B6ENA> out on the VEKSABVS, a© 
well as the signal which enables the 1/0 boards <I0EC>. 
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PAL16LS PAL DESIGN SPECIFICATION 

: PATTERN 07-702FPU7 ' 7/15/94 SUMCHECK « 6E72 
SEQUENCE DECODER 2 * FUSES BLOWN - 843 

A15 At4 A13 A12 /IOEN 

/WRITE L1BIT7 TERMRDY HOSTRDY GND 

DAS2 /IOEC /LiENA /L2ENA /L6ENA % 

/L7ENA /L8ENA /BSENA /B6ENA VCC 

IF(VCC) IOEC » IOEN * /A15 ♦ /A14 | DIRECT, Si , 52, S3 

♦ IOEN * /L1BIT7 ♦ HOSTRDY • /A13 ♦ A14 ♦ /A13 $S4,S5 

♦ IOEN * L1BIT7 * HOSTRDY * /A15 * A14 * /A13 * A12 | S3 

♦ IOEN ♦ /LIBIT7 * TERMRDY ♦ /A1S * A14 • A13 fS6 t S7 

♦ IOEN # A13 * /A14 * /A13 ♦ /A12 I FFRST v DUACK 

IF<VCC> LIENA - IOEN * A13 * /A12 fS2,D2,S6,D6 

♦ IOEN * A14 ♦ /A13 * A12 |S3,D5 

IF(VCC) L2ENA » IOEN • A13 ♦ A12 |S3,D3,S7,D7 

♦ IOEN ♦ A14 ♦ /A13 * /A12 |S4,D4 

IF<VCC) L6ENA « DAS2 ♦ IOEN ♦ WRITE * A14 # /A13 * A12 |S3,D3 
IF(VCC) L7ENA » DAS2 * IOEN ♦ WRITE * A14 ♦ A13 * A12 jS7,D7 

IF(VCC) LSENA = DAS2 ♦ IOEN * L1BIT7 ♦ WRITE * /A15 ♦ A14 * /A13 ♦ A12 J S3 

♦ DAS2 ♦ IOEN ♦ L1BIT7 * /WRITE ♦ A1S * AI4 * /A13 ♦ A12 f05 

♦ DAS2 ♦ IOEN ♦ /WRITE * A13 * /A14 * /A13 # A12 f Dl 

♦ DAS2 * IOEN * /WRITE • A15 » A14 * /A13 * /A12 J D4 

♦ DAS2 ♦ IOEN ♦ /WRITE • A15 * A13 |D2,D3,D6,D7 

IF(VCC) BSENA » IOEN ♦ /A14 ♦ /A13 * /A12 . j*D I RECT, FFRST, DUACK 

IF (VCC) B6ENA = DAS2 * IOEN ♦ /A14 ; DIRECT , DUACK , FFRST , S1-S3 , D1-D3 

♦ DAS2 ♦ IOEN ♦ A14 * /A13 * /A12 ;S4,D4 

♦ DAS2 ♦ IOEN • /L1BIT7 * A14 • /A13 » A12 |SS,D5 
+ DAS2 * IOEN ♦ L1BIT7 * /WRITE * A14 * /A13 * A12 ;S5,D3 

♦ DAS2 * IOEN ♦ A14 * A13 ;S6-S7,D6-D7 



PROGRAMMABLE ARRAY LOGIC (PAL) BOOLEAN SPECIFICATION 



The following specification is used to program the PAL 
that clocks data into the latches used to hold various data 
during the hardware assisted polling sequence. 

This PAL also generates the signal CTRCLK» used to clock 
the 4-bit counter that Increments the Compare RAM address pointer. 
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PAL16L8 

PATTERN 08-603FPU8 
! SEQUENCE DECODER 3 



3/1/94 SUMCHECK « 4292 
BLOWN FUSES » 319 



PAL DESIGN SPECIFICATION 



A15 
/WRITE 
DAS 
/L6CLK 



A14 

L1BIT7 
/LICLK 
/L7CLK 



A13 
L2BXT7 
/L23CLK 
/L8CLK 



A12 

HOSTRDY 

/L4CLK 

/CTRCLK 



/IOEN 
GND - 
/LSCLK 
VCC 



IF(VCC> L1CLK - DAS ♦ IOEN * /A14 * /A13 * A12 

IF<VCC) L23CLK - DAS * IOEN * /A14 *' *XZ « /A12 

IF (VCC) L4CLK - DAS • IOEN ♦ /LIBIT7 * /A14 * A13 * A12 

IF (VCC) LSCLK - DAS ♦ IOEN * /A14 * A13 * A12 

IF (VCC) L6CLK * DAS ♦ IOEN * A14 * /A13 * /A12 

IF (VCC) L7CLK « DAS • IOEN * A14 * A13 * /A12 



|Sl f Dl 
|S2,D2 
|S3,D3 
| S3, 03 
|S4 f D4 
|S6,06 



IF(VCC) LSCLK ■ DAS # IOEN * L2BIT7 ♦ HOSTRDY # A14 * /A13 ♦ /A12 fS4,D4 
♦ DAS ♦ IOEN * WRITE * A13 * A14 ♦ A13 * /A12 {06 ONLY 

IF<VCC) CTRCLK • DAS ♦ IOEN * /A14 * A13 ♦ A12 |S3 t D3 
«• DAS • IOEN # /LIBIT7 ♦ HOSTRDY * A14 • /A13 * /A12 |S4,D4 



tcaiaafsxassesssssssiasa 



■c=B=on33cisBsiiaaMii^aiMa«ii»ii 



PROGRAMMABLE ARRAY LOGIC <PAL) BOOLEAN SPECIFICATION 



The following apeciiication is used to program the PAL 
at defines the various control signals on the I/O board. 



PAL16LS PAL DESIGN SPECIFICATION 

PATTERN 09-914FPU9 6/13/94 SUMCHECK *« Z6E2 
I/O BOARD DECODER FUSES BLOWN * 432 

RESET /DAS /FFRST /OBVER /IOEC 

/DAS2 , /DUACK /ACKIN /BDENA GND 

INTV ; /CSENA /DATAENA /FFSRST /ACKST 

'/ACKOUT /DTACKST /DISCON NC VCC 

IF (VCC) CSENA » ACKIN * BDENA ♦ /DISCON * DAS * IOEC • /DUACK * /FFRST 

1F<VCC) DATAENA » ACKIN * BDENA * /DISCON ♦ DAS2 » IOEC * /DUACl< * /FFRST 
♦ ACKIN ♦ BDENA ♦ /DISCON * DAS2 * IOEC * DUACK * /FFRST * 

OBVER » INTV 

IF(VCC) FFSRST » ACKIN * BDENA * /DISCON # DAS * IOEC * /DUACK * FFRST 
+ RESET 

j IF (VCC) ACKST » ACKIN • BDENA * /DISCON # DAS ♦ IOEC ♦ DUACK ♦ /FFRST 

I 

i IF (VCC) ACKOUT * ACKIN ♦ /BDENA * IOEC 

+ ACKIN * DISCON QY 4023 

IF(VCC> DTACKST ■ ACKIN ♦ BDENA ♦ /DISCON ♦ DAS ♦ IOEC 
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INTRODUCTION TO COMMAND DESCRIPTIONS 

The Contention Switcher <CTSW) has many various commands 
which are used to control the system's operation. The operation 
of these commands is affected by many different things. These 
things include from which port the command is entered, which mode 
of operation the CTSW la currently in, and/or the connection 
status of any particular port. The commands are intended to be 
s flexible, functional, and consistently structured. Most of the 
commands can be conveniently abbreviated for ease of use. 
Options are available for obtaining command synt ax * information 
directl-y from the system. 

The Contention Switcher operates in several different 
modes, depending upon commands entered, battery backup status, 
and a Normal/Service mode switch located on the front edge of the 
CPU board. This switch is provided as an extra safeguard against 
inadvertently destroying any configuration information maintained 
in the battery backed up portion of the system's memory. Besides 
the SERVICE mode that this switch defines, the system may be in 
either the SHUTDOWN or the NORMAL mode of operation. One other 
mode of operation that is halfway between these two modes is the 
SHUTDOWN IN PROGRESS mode. When the CTSW is commanded to 
shutdown either by command, or by the front panel pushbutton, a 
delay occurs to allow users of the system enough time to cleanly 
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terminate their connections. 

Once the system enters the NORMAL mode of operation, a 
limited set of commands are available to any terminal that is 
connected to a contention switcher port. These commands allow a 
terminal to be able to connect to or disconnect from any one of 
the other ports in the system according to system configuration 
information. In the case of a port designated in the 
configuration as the master over one or more slave terminals, a 
command is avalable that will cause the slaved terminals to 
receive a copy of the data being received by the master terminal. 

Commands are entered in response to the " > " prompt* The 
prompt is displayed at any terminal after the item is initially 
started and any character is typed at the terminal. In the case 
of a port that has already established a connection, " > M prompt 
is obtained by entering an attention sequence. The sequence 
consists of holding the break key down longer than the configured 
break timeout period, or by entering the number of breaks 
configured as the minimum break count required for attention 
before the end of the configured break timeout period. The 
prompt is also displayed when a configurable TRIGGER message is 
received by a connected port. 

DESCRIPTION OF COMMAND SYNTAX 

CY 4025 



Commands are entered in response to the M >" prompt. 
The following notation is used for describing the syntax 
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of commands. All other symbols are entered exactly as shown. 
< > The angular brackets enclose a symbol that is replaced by 

one of a class of symbols that it represents* 
: The vertical bar indicates that a choice is to be made. 

Only one of the symbols separated by this delimiter ia 

allowed to be entered. 
{ y Curly braces enclose syntax that is optional, 
{}•• Curly braces follows by an ellipsis enclose syntax that 

is optional and may be repeated one or more times. 

/ 

The general format of a command is: 
{<and>} {/<vname>= <val>{ ,<val>K • . :<val>{ ,<val>} . . . :/<opt>} . . . 

where: 

<and> is the name of the command to be executed. If this field 
is omitted, it is assumed to be a CONNECT command. 
<vname> ia the name of a parameter with one or more associated 
values. 

<val> i s q numeric or symbolic value associated with a parameter. 
<qpt> i S the name of a parameter without an associated value. 

Alphabetical characters may be entered in upper and/or 
lower case. All commands will be converted to uppercase before 
interpretation. Each command, option, and/or value name may be 
abbreviated to its lead ambiguous form. 

Values may be entered with or without their preceding 
value names, however, if the value names are omitted the values 
must be entered in the exact order shown in each command 
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description. If a command is entered followed by a "/?" < slash, 
question mark) , .all available option and/or value names for that 
command will be displayed. 

INDEX TO COMMAND DESCRIPTIONS 

The following commands are only available at the command 
console, and only if the Normal/Service switch on the CPU board 
is in the Service position. 
DEPOSIT - Alter a memory location 

EXAMINE - Examine memory locations 

MEMTEST - Exercise memory locations 

INITIALIZE - Initialize battery backup memory 

The following commands are only available at the command, 
console, and only if the system is in the shutdown mode. 
DOWNLOAD - Receive configuration information from a host port. 

DUARTTEST - Execute Duart Diagnostic test 
RESET - Perform a System Reset 

SEQUENCER - Execute Sequencer Diagnostic test 
STARTUP - Begin NORMAL operational mode 

UPLOAD - Transmit configuration information to a host port. 

The following commands are available in both shutdown 
and/or operational mode at the command console only. 
GROUP - Establish a name for a collection of ports. 
LOGGER - Start/Stop logging activity for specified ports. 
MESSAGE - Establish a symbol name for a string of text. 
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OVERRIDE -Cause slaved terminals to copy master terminal. 
SETUP - Alter configuration parameters of system ports. 
SHOW - Display configuration parameters of system ports. 
SHUTDOWN -End operational mode. 

STATUS -Displays the operational status of system ports. 
TIME - Display or set Time of Day clock. 

The following commands are available at any port only 
when the CTSW is in the NORMAL operational mode. 
CONNECT - establish a port to port connection 
DISCONNECT - break a port to port connection 
OVERRIDE - override slaved terminal's connections 

CONNECT PORT COMMAND 
CONNECT < /T0« > <group> C /FROM- > <term> </WAIT-> <nwait> 



where : 
<group> 

<term> 

<nwait> 



identifies the port or group of ports to connect 



to. 



identifies the port to be connected. This option 
may only be specified from a privileged port. 

is the queuing threshold indicator. If the 
number of other connection requests already 
waiting for a port from the desired group exceeds 
this number, then the connection request will not 
be queued. The default queuing threshold is 
three connection requests. Qy 4Q28 
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The CONNECT command establishes a connection to another 
port. If the command' is entered without specifying any 
parameters, the port will be connected to one of the default 
connection ports, if any. If a connection was temporarily 
suspended as the result of a break attention sequence or a 
TRIGGER match, the connection will be resumed instead. 

When the CONNECT commands specifies connection to a group 
of porta, the first available port in that group with a 
configuration compatible with the port to connect will be used as 
the port to connect to. If all of the available ports in the 
group are already connected to other ports, then the connection 
request is placed in a queue, provided that the number of 
connection requests already queued for this group is less than 
the threshold specified by the /WAIT parameter. 

If there are no ports in the specified group that have a 
compatible configuration (baud rate, bits per character, etc.) 
with the port to be connected, then an appropriate error message 
will be displayed. 

If a GROUP name is entered in response to the " > " 
prompt, it will be interpreted as if the group name had been 
specified on the "/TO" option of the CONNECT command. 

DEPOSIT MEMORY COMMAND 

DEPOSIT < /START- > <addr> < /DATA- > <data> 

i / INTERVAL— > <intv> < /REPEAT- > <rept> 
< /BYTE I /WORD 1 /LONG > 
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where: 

<addr> is up to six hex digits defining the ayatejn memory 
address to modify. 

<data> is the data to store at the specified address. An error 
message is displayed if the data will not fit into the 
memory entity type selected. A memory entity is either a 
byte, a word, or a longword of memory. 

<intv> is the interval between entities of memory to modify. If 
specified as zero, the same memory location is repeatedly 
modified. If specified as one, sequential addresses are 
modified. If specified to be two every other memory 
entity will be modified. Et cetera, et cetera. 

<rept> is the number of times to repeat the command. If zero is 
specified, or no value follows the /REPEAT option, the 
command is repeated indefinitely, or until a break is 
typed at the console. 

/BYTE causes one byte of memory to be modified. This is the 

default system memory display format. 

/WORD .causes one word of memory to be modified. Only even 

addresses may be modified in this mode. 

/LONG causes one longword of memory to be modified. Only even 

addresses may be displayed in this mode. 

CY 4030 
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CPU board ia in the Service position. The modified memory 
location ia displayed in hexidecimal after the memory location ia 
changed. 

DISCONNECT PORT COMMAND 
DISCONNECT i /PORT- > <pname> 
where : 

<pname> identifies the port to be disconnected. 

The DISCONNECT command breaks a connection between porta. 
When thia command is entered on the command console, it requires 
the name of a port to disconnect. If the specified port is not 
connected, an error will be- displayed. 

When this command is entered at a terminal port, that 
port is defined as the port to disconnect and the /PORT option is 
not allowed. 
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TEST DUARTS COMMAND 



DUARTTEST t /BOARD- > <board> < /CHIP- > <chip> 

i /TESTS- '> <tnum>< f <tnum» < /REPEAT- > <pat«M> 
< /INTERVAL- > <intv> < /WAIT- > <wait> < /LOOP > 

where : 

< board > defines which board to exercise. Board zero refers to 

the CPU board. I/O boards are numbered from one to four. 
All of the I/O boards are tested if the BOARD option is 
not specified. 

< chip> identifies a specific DUART chip to exercise. Ail DUARTs 

on the selected board are exercised if this option is not 
specified • 

< tnum> identifies a specific desired DUART test to execute. If 

this option is not specified , then all of the DUART 
tests will be executed. 

< passes> is the number of times to repeat the test. If zero is 

specified, or no value follows the /REPEAT option, the 
command is repeated indefinitely , or unti 1 a break is 
typed at the terminal. 
<intv> specif ies the Interval between pass completion messages . 
If specified as zero, each test identifies itself on a 
separate line along with a PASS/FAIL indication. If the 
INTERVAL is specified as a non-zero value , then the test 
identification will not be produced, unless a test falls. 
If all of the tests specified pass, then the message that 
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indicates the number of successfully completed passes is 
output -at the specified interval between pass messages. 
<wait> specifies a wait count. A delay of approximately 1.25 
microseconds per count is added at various points during 
the test in order to visually identify certain specific 
events by observing the LEDs on the boards. A wait count 
of zero indicates that the test should run at full speed. 
/LOOP causes the test to loop on any condition that generates 
an error. This allows visual display of signals on an 
oscilloscope . 



The DUARTTEST Command exercises one or more DUARTs. The 
test is divided into three ma^or parts. The first part of the 
DUART tests exercises one DUART at a time. The second part of 
the test exercises one I/O board at a time, and the third part of 
the test exercises all of the I/O boards at the same time, as 
well as the interrupt handling circuitry on the CPU Board. 

The first part of the DUART test is divided into seven 
tests. Test zero writes and reads back all 256 possible 8-bit 
data patterns to and from the DUART interrupt vector register. 
Test one writes and reads back the same data patterns from both 
mode registers of DUART channel A. Test two checks the mode 
registers of DUART channel B. 
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TEST DO ARTS COMMAND (continued) 

The DUART is then initialized end both DUART channels are 
setup into the data loopback mode. Test three sends all of the 
8-bit data patterns to the channel A transmitter and checks them 
when they are received at the channel A receiver. Test four 
tests channel B of the DUART in a similar fashion. 

Finally, test five enables DUART interrupts for Channel A 
and commands the channel A transmitter to START BREAK • When the 
interrupt is received from the channel A receiver, it is checked 
in order to verify that it came from the correct DUART., The 
channel A receiver buffer is checked for the correct break 
indicator character and the channel A transmitter is commanded to 
STOP BREAK. When the next CHANGE IN BREAK interrupt is received 
and verified, of if the interrupt is not received within a fixed 
timeout period, further interrupts from channel A of the DUART 
are disabled. Test six is a similar test for channel B of the 
same DUART. 

The second part of the DUART test begins with test seven, 
which is executed only after all sixteen DUARTS on an I/O board 
have been tested. Initially, all normal DUART interrupts are 
prevented from interrupting the CPU by writing to the CPU status 
register. Then all sixteen DUARTs on the selected I/O board are 
caused to interrupt. This generates a FIFO FULL condition on the 
I/O board which causes a FIFO FULL interrupt at the CPU which, 
after being accounted for, will allow the processor to resume 
normal DUART interrupt handling. The test will fail if all of 
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the expected interrupts are not received within a fixed timeout 
period. 

The third part of the DUART test begins with test eight , 
which executed only after the first two parts of the test are 
successfully completed on all of the selected I/O boards. This 
portion of the test simulates the complete operating environment 
of the contention switcher including the sequencer. The mapping 
RAM is setup to send the characters received by PORT A of the 
first DUART to the transmitter of PORT B. The characters looped 
back from PORT B are then moved by the sequencer to the PORT A 
transmitter of the next DUART being tested. All of the DUARTs 
under test are similarly chained together except that the 
characters received at PORT B of the last DUART in the chain are 
not moved by the sequencer. The Compare RAM is initialized with 
8 strings of 16 descending values. The Pointer RAM pointer for 
each DUART under test is initialized to point to one of the 8 
compare strings. The sequencer status byte for each DUART under 
test is cleared. A simulated polling sequence is started at 
regular intervals and the test begins. All 256 character 
patterns are pushed into the PORT A transmitter of the first 
DUART and each character is checked as it is received at PORT B 
of the last DUART. If all of the characters match, and the 
sequencer status byte for each DUART indicates that the compare 
string ' matched, the test reports successful completion. 
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EXAMINE MEMORY COMMAND 

EXAMINE < /START- } <addr> i /COUNT- > <count> 

< /INTERVAL- > <intv> < /REPEAT- > <rept> 

< /BYTE I /WORD I /LONG > 

where: 

< addr > is the first ayatea memory address to examine and 
display. The value entered is assumed to be in 
hexidecimal unless otherwise indicated. 

<count > is the total number of memory entitys to examine. A 
memory entity is either a byte, a word, or a longword of 
memory. The value entered is assumed to be in decimal 
unless otherwise indicated. 

< intv > is the interval between displayed entities of memory. If 
specified as zero, the same memory location is repeatedly 
accessed. If specified as one, sequential accesses are 
made. I* specified to be two every other memory entity 
will be accessed. Et cetera, et cetera. The value 
entered is assumed to be in decimal unless otherwise 
indicated. 

< rept > is the number of times to repeat the command. If zero is 
specified, or no value follows the /REPEAT option, the 
command is repeated indefinitely, or until a break is 
typed at the console. The value entered is assumed to be 
decimal unless otherwise indicated. 

/BYTE causes the memory display to be formatted in bytes. This 

is the default system memory display format. 

/WORD causes the memory display to be formatted in words. Only 

even addresses may be displayed in this mode. 
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/LONG cauaea the. aemory diaplay to be formatted in longworda. 

Only even addressee may be displayed In this mode. 

The EXAMINE Command examines a block of system memory. 
This commend may only be used if the Normal/Service switch on the 
CPU board is in the Service position. Up to sixteen bytes of 
memory are displayed on each line* in hexldeclmal numbers 
formatted appropriately for the selected memory entity type. 
Each displayed line has the ASCII character representation for 
the data on that line appended to the end of the line. If a byte 
of data has no corresponding ASCII representation, a period < . > is 
displayed. 

DEFINE GROUP OF PORTS COWHAND 

GROUP < /NAME- > <group> < /ADD* > <port> < ,<port> > 

< /DELETE > < /REMOVE 5 * > <port> < f <port> > 

< /RENAME- > <rname> < /DELETE > 

where: 

<group> identifies the group to be displayed, modified or 
renamed. 

<port> identifies a port or group of ports to be added to or 

removed from the group. 
/DELETE indicates that the group is to be dissolved. All ports 

are removed from the group and the group name and the 

memory space allocated for the group is released. 
<rname > is a new identification for the same group. Any 

references to the old group name continue to refer to the 
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new group. 

The GROUP command establishes a collection of porta. If 
a group name is specified with no other options, then a list of 
-the ports belonging to that group is displayed. Ports may be 
added to a new group or an already existing group. Porta, may 
only be removed from already existing groups. 

I£ no options are specified on the GROUP command, a iist 
of all of the existing groups are displayed. A maximum of (???) 
groups may be established at any one time. 

Port groups have many useful purposes in the command 
structure. The most important use of a group is to identify the 
ports that the CONNECT command will use to satiafy a connection 
request. Other uses include identifying ports to be logged 
< LOGGER . command), ports to be slaved to other terminals < OVERRIDE 
command), and ports to change the configuration of (SETUP command). 



INITIALIZE CONFIGURATION MEMORY 



INITIALIZE { /ALL 



/CONFIG 



/SYMBOLS) 



where: 



/ALL 



causes all battery backed-up data structures to be 



initialized. 



/CONFIG 



causes only" configuration information to be 



initialized. 



/SYMBOLS 



causes only symbol information to be initialized. 
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The INITIALIZE command initializes data structures 
contained in the battery backup memory. Any previously entered 
configuration information and/or symbol definitions (groups, 
messages, etc..) are deatroyed. Thia command may be executed 
only from the conaole and only If the normal/service awitch on 
the CPU board ia in the SERVICE poaition. 

SYSTEM RESET COMMAND 



RESET 

Thia command performs the equivalent function of a ayatem 
reaet. A ayatem reaet can be cauaed by ayatem power up, watchdog 
timeout, or by pushing the reaet button on the front edge of the 
CPU board. System reaet is the only point in time that the 
SERVICE mode of operation may be entered. If the put into normal 
operation with the STARTUP command, the SERVICE mode will be 
terminated, and another ayatem reset is required in order to get 
back into service mode. The RESET command may only be executed 
when the ayatem in the SHUTDOWN mode. 

LOGGER PORT CONTROL COMMAND 

LOGGER < /PORT- > <pname> < /START I /STOP > 

<pname > identifies the port or group of ports to be logged. 

/START indicates that logging is to begin. 

/STOP indicatea that logging is to be terminated. 
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The LOGGER connand causes all activity of a port or group 
of ports to bo logged at the logger port. Activity logged 
include* connections to the port, disconnections of the port and 
any failures related to the port. 

If the LOGGER conmand is entered without either the 
/START or the /STOP option, then the logging status of each 
affected terminal will be toggled to be opposite to its previous 
state. 
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TEST MEMORY COMMAND 

MEMTEST < /START- > <«ddr> < /COUNT- > < count > 

i /INTERVAL- > <lntv> € /REPEAT- > <r»pt> 
< /BYTE I /WORD I /LONG > 

where : 

< addr > ia up to aix hex digita defining the first ayatem memory 

addreaa to exerciae • 
< count > ie the total number of memory entitya to teat. A memory 

entity ia either a byte, a word, or a longword of memory. 
< intv > ia the interval between teated entitiea of memory. If 

apeclfied aa zero, the same memory location ia repeatedly 

teated. If apecified as one, sequential acceaaea are 

made. If specified to be two, every other memory entity 

will be teated. Et cetera, et cetera. 
< rept > is the number of timeeto repeat the command. If zero ia 

apecified, or no value follows the /REPEAT option, the 

command ia repeated indefinitely, or until a break is 

typed at the console. 
/BYTE causea the memory display to be formatted in bytes. Thia 

is the default system memory display format. 
/WORD causes the memory display to be formatted in words. Only 

even addreaaea may be displayed in this mode. 
/LONG causea the memory display to be formatted in longworda. 

Only even addresses may be displayed in this mode. 

The MEMTEST Command exercises a block of system memory. 
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Thia command may only be used if the Normal/Service switch on the 
CPU board la in the Service position. The test is divided into 
three parts. 

The first test exercises memory one byte at a time. 
Various data patterns are written to and read back from each byte 
of memory in the specified area. If the data read back from a 
memory location does not verify , the memory address, expected 
data, and actual data read back are output to the command console. 

The second test is similar to the first except that the 
memory is tested one word at a time instead of one byte at a 
time. If the start address of the memory area to test is odd, 
this portion of the memory test will not run. This allows 
testing of memory areas that are byte-addressable only. 

The third test writes a test pattern to each byte of 
memory in the specified area and then checks other locations 
within the specified area to insure that they have not been 
modified. If a location that should not have been modified is 
changed, the memory address, the modified memory address, and the 
actual data read back are output to the command console. 

DEFINE MESSAGE COMMAND 

MESSAGE < /NAME- > <name> < /EXIT- > <char> < /RENAME- > <rnam«> 
< /ASSOCIATE- > <aname> i /DELETE > < /TRIGGER > 

where: 

<name > identifies the message to be displayed, modified or 



copied. 
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< char > identifies the character which will identify the end of 

the message test. The default message text terminator 
is a carriage-return character. This option must be used 
if a multiple line message is to be entered. 

< rname > is a new name for the same message. Any references to 

the old message name continue to refer to the same 
message text • 

aname identifies the name of a trigger message to associate 
this message with. When a port that uses the associated 
trigger is disconnected from, this message is transmitted 
to that port. The specified message should cause the 
host computer attached to that port to logoff any user 
logged in at that port, and/or any other desired actions 
upon disconnect. 
/DELETE indicates that the message is no longer required. Any 
text associated with the message name as well as the 
memory space allocated for the message name itself is 
released. If there are any references to the message 
name to delete, an error message will be displayed and 
the message will not be deleted. 
/TRIGGER indicates that this is a disconnect trigger message. 
The message text may not exceed 16 characters. A 
question mark in the message text will match any 
character in that position. 
The MESSAGE command establishes a named text string. 
This text is then referenced by other commands. The total number 
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of characters defined by all of the message strings may not 
exceed (???). 

*If the /TRIGGER option is specified on the MESSAGE 
command, then the text associated with the message name is used 
to trigger a disconnect timeout. If no characters are received 
from the terminal port within the specified timeout period, after 
the trigger string has been received from the host port, then the 
connection between the two ports will be terminated. If there is 
a message associated this trigger it will be transmitted to the 
host port as part of the disconnect sequence. 

A maximum of eight <S> trigger messages may exist at any 
one time. Any question mark characters specified in the trigger 
text will match any single character received from the host port 
in that character position. The trigger message cannot- be longer 
than a maximum of sixteen (16) characters. 

OVERRIDE SLAVE PORTS COMMAND 

OVERRIDE t /PORT- ) <pname> < /SET I /CLEAR > 
where: 

< pname > identifies the port or group of ports to be overridden. 
/SET indicates that override is to be established. 
/CLEAR indicates that override is to be terminated. 



The OVERRIDE command causes a port or group of ports 
temporarily receive a copy of all data received at the terminal 
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port that is configured as the master for the selected ports. 
This command may be entered from any terminal, however it will 
only affect ports which are configured with /MASTER set to the 
port that the command is entered from. 

If the OVERRIDE command is entered without either the 
/SET or the /CLEAR option, then the override status of each 
effected terminal will be toggled to be opposite to its previous 
state. 

If no ports are specified on the OVERRIDE command then 
all ports which are configured with /MASTER set to the port that 
the command is entered from are affected. If the command is 
entered from the command console, all ports that have /MASTER 
set to any port other than NONE will be affected. 
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TEST DUART SEQUENCER COMMAND 




< /INTERVAL* > <rept> < /WAIT- > <wait> 




> <pass««> 

€ /LOOP > 



where : 



< tnum> 



identifies a specific desired DUART test 



to execute. 



If 



this option is not specified, then all of the DUART tests 
will be executed. 

<passea>is the number of times to repeat the test. If zero is 
specified, or no value follows the /REPEAT option, the 
command is repeated indefinitely, or until a break is 
typed at the terminal. 

<intv> specifies the interval between pass completion messages. 
If specified as zero, each test identifies itself on a 
separate line along with a PASS/FAIL indication. If the 
INTERVAL is specified as a non-zero value, then the test 
Identification will not be produced, unless a test fails. 
If all of the tests specified pass, then the message that 
indicates the number of successfully completed passes is 
output at the specified interval between pass messages. 

< wait > specifies a wait count. A delay of approximately 1.25 
microseconds per court is added at various points during 
the test in order to visually identify certain specific 
events by observing the LEDs on the boards. A wait count 
of zero indicates that the test should run at full speed. 

/LOOP causes the test to loop on any condition that generates 
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an error. This allows visual display of signals on an 
oscilloscope. 

The SEQUENCER Command exercises the sequencer logic on 
the CPU board • The test is divided into several steps. The 
first three steps run memory test routines on the Compare, 
Mapping and Pointer RAMs . The fourth step writes all 256 
possible characters and reads back from the latch used to hold 
the characters copied to slaved terminals. The fifth and sixth 
step tests all 12S possible DUART addresses that can be latched 
into the two DUART address latches. The seventh step writes all 
256 possible status values to both DUART port status byte latches 
and checks the sequencer status byte for correct settings. The 
eight step checks all 256 character patterns against 256 
different character patterns stored in the Compare RAM by using 
the sequencer comparator and checking the sequencer status byte 
for correct setting of the message match bit. The ninth step 
tests that the pointer that is used to address the Compare RAM 
can be incremented thru all compare RAM addresses and that it 
resets to the beginning of the message when a character does not 
match. 
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SETUP PORT CONFIGURATION COMMAND 



SETUP { /PORTS- > ALL ! <pname>< f <pname» 

i /BAUD* > 9600 I 7200 ! 4800 I 2400 L 2000 I 1800 

11200 J 600 I 300 I 150 I 134.5 I 110 I 75 
€ /BITS_PER_CHAR- > 5 I 6 S 7 I 8 * 

< /STOP_BITi» > 1.0 I 1.5 ! 2.0 

€ /PARITY- > EVEN ! ODD I MARK I SPACE I NONE 

< /TIMEOUT- > <tmo> < /TRIGGER- > <trmsg> I NONE 
C /WELCOME- > <wmsg> ! NONE < /CONNECT- > <cnam«> 

< /MASTER- > <mport> ! NONE < /RESTRICT- > <rname> I NONE 
t /PRIVILEGE- > CONFIG ( DIAG I INFO 1 OPER 

< /DISABLED : /ENABLED > < /MODEM I /NOMODEM > 
C /STARTED > < /LOCKED > 



where: 

<pname> is a port identifier or group name identifying the port 

or group of ports to be configured. 
<baud> specifies the baud rate of the specified port or ports. 

Initially, all baud rates are 'set to 9600 baud. 
/BITS specifies the number of bits per character for the port 

or group of ports specified. Initially, all ports are 

set to send and receive 8 bits per character. 
/STOP specifies the length of the stop bit used for the port or 

group of ports specified. Initially, all ports are set 

to send and receive 1 stop bit per character. 
/PARITY specifies the parity type of the specified port or ports. 

Initially, all ports are set to /PARITY^NONE. 
< tmo >specif ies the number of minutes of inactivity before an 

prompt is automatically issued. If the prompt is 

not responded to within 15 seconds a disconnect will 

occur. Cy 4048 
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< trig> specifies one of the logoff trigger messages. If 

connected to a port that has a trigger specified, when 

the trigger message is received from that port, an 

prompt is automatically Issued. 

< wmsg > specifies a welcome message. This message is sent to the 

port when the 'port is first issued an prompt. 

< connect > is a port identifier or group name identifying the port 

or ports this port is connected to by default. Refer 
to the /START option and/or the CONNECT command for 

detail • 

< master>is a port identifier or group name identifying the port 

or ports which may override this port's connection. 
Initially, all ports are /MASTER=NONE . 

< rstrctMs a port identifier or group name • identifying the port 

or group of ports that are allowed to connect with this 
port. Initially, there are no restrictions on any 
ports. 

SETUP PORT CONFIGURATION COMMAND (continued) 

/PRIVILEGE indicates which kind of commands are to be 

allowed to be executed at the port or ports being 
configured. 

/DISABLE marks the port or group of ports as unavailable. 
/ENABLE marks the port or group of ports as available. 

All responding ports are initially enabled. 
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/MODEM identifies the port or group of ports as being 

r 

connected through a modem. This setting is only 

valid for the first out of each four ports. 
/NOMODEM identifies the port or group of ports as being 

directly connected. This is the initial setting 

for all ports. 
/STARTED identifies the port or group of ports to be 

automatically connected upon system startup. The 

port will be connected to one of the ports 

defined by the /CONNECT option. 
/LOCKED identifies the port or group of ports as being 

permanently connected. Prompts, timeouts and 

triggers are disabled for each port, with the 

/LOCKED attribute. 
The SETUP command is used to alter or display the 
configuration parameters of one or more ports. If the SETUP 
command is entered with no other options, the configuration of all 
of the ports is displayed. If the name of a port or group of 
ports is the only supplied parameter, then the configuration 
parameters are displayed for those ports only. 

Alteration of the configurable parameters for a port will 
only affect the port upon reinitialization of that port. All 
ports are reinitialized when the system is initially started. 

When a port is disabled, no new connections are allowed 
to be made to or from that port. Any existing connection remains 
valid until terminated in the normal fashion. Connections may be 
forced from any privileged port. 
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If a trigger message ia specified for a port, then during 
any connection to that port, the data stream received from that 
port ia continuously monitored for the specified message. 
Whenever the specified message is received from the triggered 
port, a timeout sequence is started for that connection. If no 
characters are sent to the triggered port before the end of the 
specified timeout period, the connection will be terminated. 



SHOW ' SHOW PORT CONFIGURATION COMMAND SHOW 



SHOW < /GROUP- > ALL I < group >< ,<group» 

< /BAUD=» > 9600 t 7200 ! 4800 I 2400 I 2000 I 1800 

51200 S 600 I 300 I 150 t 134. S I 110 I 75 

< /BITS PER CHAR= > 5 ! 6 I 7 I 8 

< /ST0P~BITS» > 1. 0 11. 5 1 2.0 

< /PARITY- > EVEN S ODD ! MARK I SPACE I NONE 

I /TIMEOUT- > <tmo> < /TRIGGER- > <trmsg> I NONE 

< /WELCOME- > <wmsg> ! NONE < /CONNECT- > <cnam«> 

< /MASTER— > <mport> 5 NONE < /RESTRICT- > <rna«it> I NONE 
i /PRIVILEGE- > CONFIG I DIAG ! INFO I 0PER 

< /DISABLED ! /ENABLED > < /MODEM I /N0M0DEM > 
C /STARTED } i /LOCKED > < /ZPRIV > 
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where: 

< group > is a port identifier or group name identifying the port 

or group of ports to show the configuration of • 

< baud > restricts the command to display only those ports which 

are configured with the specified baud rate . 
/BITS restricts the command to display only those ports which 

are configured with the specified number of BITS per 
character • 

/STOP restricts the command to display only those ports which 

are configured with the specified stop bit length . 

/PARITY restricta the command to display only those ports which 
are configured with the specified /PARITY setting. 

< tmo >restricts the command to display only those porta which 

are configured with the specified TIMEOUT period. 

< trig> restricts the command to display only those ports which 

are configured with the specified TRIGGER message. 

< wmsg> restricts the command to display only those ports which 

are configured with the specified WELCOME message. 

< master >restricts the command to display only those ports which 

are configured with the specified master ports. 

< ratrct>restricts the command to display only those ports which 

have the specified connection restrictions. Qy 4Q52 
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/PRIVILEGE restricts the command to display only those ports 

which have'the specified set of privileges. 

SHOW PORT CONFIGURATION COMMAND 

/ENABLE restricts the command to display only those ports which 
are enabled. 

/DISABLE restricts the command to display only those ports 

which are disabled. 
/MODEM restricts the command to display only those ports which 

are configured as being connected to a MODEM. 
/NOMODEM restricts the command to display only those 

ports which are configured a© not being connected 

to a MODEM. 

/STARTED restricts the command to display only those ports 
which are configured to be connected upon system 
startup. 

/LOCKED restricts the command to display only those ports 

which are configured such that their connections 
are LOCKED. 

The SHOW command is used to display the configuration 
parameters of one or more ports. If the SHOW command is entered 
without parameters, the configuration of the port that the 
command was entered from is displayed. 

Specification of any of the configurable parameters will 
restrict the display to only those ports that are configured as 
per the parameters specified. 
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START OPERATIONAL MODE COMMAND 



STARTUP 

The STARTUP command causes the contention switcher to 
enter the operational mode* Diagnostic commands are disabled, 
permanent and/or temporary connections defined in the 
configuration tables are established, and all other enabled 
terminal ports are allowed make connections. This command may 
only be entered at the command console. 

END OPERATIONAL MODE COMMAND 

SHUTDOWN { /WAIT= ) < wait > ( "/MESSAGE* } < mess > 
where: 

< wait > is the number of minutes to wait before shutting down. 

The default shutdown delay is 5 minutes. 

< mess> specifies a message which will be broadcast to all 

connected terminal ports, indicating the reason for 
shutdown or other appropriate message. 

The SHUTDOWN command causes the contention switcher to 
exit the operational mode. Initially, all terminal ports are 
disabled from establishing new connections. After the specified 
waiting period, all logical connections are broken and the CTSW 
enters the shutdown mode. 
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DISPLAY PORT STATUS COMMAND 

STATUS { /GROUP 3 ) ALL :< group > (,<group>) 
( /QUEUES ) ( /SYMBOLS ) 

where: 

< group > displays information about the current state of the 

selected port or group of ports. 
/QUEUES displays information about the current state of the 

various systems queues. 
/SYMBOLS displays information about the system symbol table. 

The STATUS command is used to display information about 

the operating state of the system. If the STATUS command is 

entered without specifying any parameters, all available status 
information is displayed. 

DISPLAY/SET TIME OF DAY COMMAND 

TIME ( /SET } 
where: 

/SET indicates that time and date are to be set. 

The TIME command displays the system date and time. This 
command may be entered from any terminal port. 

If the TIME command is entered with the /SET option then 
the current date and time is prompted for. The /SET option is 
only allowed from the command console port. CY 4055 
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CLAIMS 

1. Electronic switching system for making logical 
connections between at least one computer and a plurality of 
computer terminal devices comprising , 

a plurality of asynchronous receiver-transmitters (ART) 
for converting serial binary data to and from parallel binary 
data, one ART for each said at least one computer and each of 
said plurality of computer terminal devices, respectively, and 
means for connecting each respective said computer terminal 
devices and computer to an ART, respectively, 

a microprocessor, 

memory means- controlled by aaid microprocessor for 
storing the identity of computer terminal devices and, said at 
least one computer and the respective ART to which they are 
connected and a connection table of current logical connections 
between pairs of said ARTS, 

sequencer logic means controlled by said microprocessor 
for receiving connection request signals from one of said 
terminals for connection to a specific computer, and sequentially 
establishing a logical connection between the ART to which said 
one of said terminals is connected and the ART to which said 
specific computer is connected. 

2. Electronic switching system as defined in claim 1 
wherein there are a plurality of ports on said one or more 
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computers, each of said ports being connected to one of said 
ARTS , respect ivel y . 

3. Electronic switching system as defined in claim 1 
wherein there are a plurality of said computers, each having one 
or more ports thereon, and means connecting each said port to one 
of said ARTS, respectively. 

4. Electronic switching system ass defined in claim 1 
including means for monitoring and comparing information data 
exchanged between logically connected ART pairs to detect hiatus 
in data transfer for a predetermined period of time, and 
generating a disconnect signal for said logically connected ART 
pairs. 

5. Electronic switching system as defined in claim 4 
including self -addressed memory means controlled by said 
microprocessor for storing requests from terminals for connection 
to selected ARTs, respectively. 

6. Electronic switching system as defined in claim 1 
wherein said sequencer logic means includes a plurality of 
programmed array logic (PAL) circuit chips. 

7. Electronic switching system as defined in claim 1 
including at least one further ART connected solely to said 
microprocessor for entering and retrieving data therefrom. 
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